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Histoire 
Histoire des des batailles 


DATAILLES. dvi. 


aux missiles 


| N AVA L F S Des duels de l'Antiquité au 
lu 


conflit des Malouines, cet 
de la voile aux missiles ouvrage retrace vingt-cinq 
siècles de guerre sur mer. 
Ce livre, vivant et précis, illustré 
de documents anciens et récents 
sur les navires, les hommes et 
les opérations qui ont marqué 
le contrôle de la mer, restitue aux 
conflits maritimes leur place 
primordiale dans l'histoire de 
la guerre. 


Un volume relié, sous jaquette 
illustrée. 224 pages. 97 photos, 

2 dessins et 2 cartes en couleurs. 
110 photos et 4 cartes en noir 

et blanc. 

Format : 22,5 x 29,5 cm. 
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Le système solaire 
et son exploration 


L'aventure de l'observation du 
ciel commence par l'exploration 
de notre système solaire. C'est à 
la découverte des planètes, des 
satellites, des astéroiïdes, des 
comètes et des météorites qui le 
composent que vous convie cet 
ouvrage. || permet aussi de 
revivre l'épopée spatiale qui 
marque la seconde moitié du 
XX siècle. 

Véritable promenade par les 
chemins de l'Univers, Le Système 
solaire et son exploration dévoile 
un monde fascinant. 


Un volume relié. 

Couverture illustrée. 200 pages. 
144 photos, 74 dessins et 
schémas en couleurs. 

13 photos en noir et blanc. 
Format : 22 x 28,5 cm. 
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Faites vos jeux 


On vend chaque année des millions de jeux pour micro-ordinateurs. 
Les firmes productrices de logiciels ont trouvé judicieux de proposer 
à leurs clients des programmes générateurs de jeux. 


Créateur de jeux 
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Configuration 
Ce menu vous donne 


ER diaas 1. HOLUIS | 
la possibilité de choisir ere 

la direction dans laquelle AROUND + G 

se déplace votre base, 
les couleurs du fond et 

de l'avant-plan, la façon 
dont apparaissent 

les extraterrestres, ainsi 
que les effets sonores. 


...ALIEN ENPLOUE 


SELECT TER: EN 


Mouvement 

Vous pouvez, grâce à ce 
menu, déterminer la 
manière dont surviennent 
les attaques. En haut et à 
droite de l'écran, un 
diagramme ; en bas, un 
écran où viennent s'afficher 
les déplacements. 


SELECT PATTERN: DEN 


Il existe deux grands types de « ludiciels » : les 
jeux d’aventures, auxquels le joueur doit parti- 
ciper activement, et qui peuvent ou non être 
illustrés graphiquement, comme c’est le cas de 
The Hobbit; et les jeux comme Space Invaders 
ou Asteroids, qui se limitent à l’écran même, au 
point que l’on pourrait y voir des « simulations 
imaginaires ». 

Une analyse superficielle de ces deux genres 
montre les raisons de leur similitude. Pour pren- 
dre l’exemple de Space Invaders, il faut, pour 
jouer, deux éléments principaux : une base 
(vaisseau galactique, station spatiale, etc.) dotée 
d’une puissance de feu, et des cibles sur lesquel- 
les on peut tirer. Il est donc possible, en modi- 
fiant à chaque fois ces deux paramètres de 
départ, d’obtenir une grande variété de jeux, 


< Au début 


CE TN EN LRELCTE ] 


Les objets graphiques 
apparaissent d'abord sur un 
fond uni, et descendent de 
façon lente et ordonnée. 
Résultat final 

On voit ici quelles 
modifications ont été 
apportées aux éléments 
initiaux : seul le chat reste 
inchangé. 

Ld 


SHIFT TO coLou 
enrun vo Pin 


différant entre eux par certains détails : position 
du défenseur, armes à sa disposition, rythme et 
intensité des vagues d’assaut. Il suffit d’ailleurs 
de comparer entre eux bien des programmes 
commerciaux d’allure semblable pour voir que 
c’est précisément ce que font les firmes produc- 
trices. 

Un bon exemple de logiciel vous permettant 
de faire de même est le Games Designer (« Créa- 
teur de jeux ») de John Hollis — qui n’avait que 
seize ans à l’époque où il l’écrivit.. Mis en vente 
par Software Studios/Quicksilva, il fonctionne 
sur Spectrum 48 K. Ce programme vous pro- 
pose huit types de jeux fondamentaux. Une fois 
que vous en avez choisi un, il vous est possible 
d’en modifier les paramètres. Mais vous ne 
pourrez pas créer de jeux nouveaux; vous 


< Création de figures 


On peut remplir 

{ou effacer) chaque point 
en sélectionnant 

les coordonnées 
correspondantes. On peut 
voir en bas de l’écran la 
figure sous sa forme 
définitive (taille, couleur). 
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McKinnel 


lan 


devrez vous contenter de ceux qui vous sont pré- 
sentés. Ils sont toutefois de bonne qualité. 

La mise au point se fait par l’intermédiaire de 
menus. Une fois que vous avez fait votre choix, 
vous pouvez procéder à diverses modifications, 
en commençant par la forme et la couleur des 
objets graphiques qui représenteront les prota- 
gonistes. Ils sont déjà définis, mais c’est plus un 
avantage qu’un inconvénient dans la mesure où 
vous pouvez les modifier, bit par bit, au sein 
d’une matrice de dimensions 12 X 12 (c’est-à- 
dire un carré formé de quatre caractères). Vous 
pouvez également, si vous le désirez, partir 
d’une « feuille blanche » de même format. Les 
objets graphiques ou figures ainsi obtenus sont 
parfaitement lisibles et reconnaissables. 

Le dessin de ces objets est lui-même guidé par 
un menu, qui affiche sur la gauche de l’écran les 
différentes options disponibles, et à droite une 
image agrandie du motif. Celui-ci est d’ailleurs 
reproduit en bas de l’écran, en dimensions et en 
couleurs « réelles », ce qui se révèle très utile. 

On doit alors définir le mouvement de tous 
ces objets. C’est le rôle d’une partie du pro- 
gramme intitulée « Configuration ». Elle ne 
vous permet pas seulement le contrôle des direc- 
tions de chaque protagoniste : à chaque fois il 
vous est proposé plusieurs types de mouvement 
que vous pouvez, si besoin est, fondre en un 
seul. Il vous faut ensuite décider des déplace- 
ments des éléments du décor. 

Après quoi reste à régler la fréquence des 
vagues d’assaut, et à insérer certains effets spé- 
ciaux, visuels et sonores. 

Une fois qu’on a créé un jeu, il convient de le 
sauvegarder sur cassette ou sur disquette, afin 
de pouvoir y jouer plus tard. C’est là que — du 
point de vue de l’utilisateur — Games Designer 
se révèle d’une grande insuffisance : il n’est pas 
possible de stocker le programme tel quel sur 
une mémoire auxiliaire. On ne peut préserver de 
cette façon que les données relatives aux para- 
mètres qu’on a définis; pour jouer, il faut char- 
ger en mémoire Games Designer, puis les don- 
nées elles-mêmes. Il est donc impossible de 
mettre au point un jeu particulier avec l’idée de 
le commercialiser plus tard. 


The Quill 


The Quill (« La Plume d’oie ») est, au contraire, 
expressément destiné à ceux qui désirent créer 
des jeux d’aventures et les mettre sur le marché. 
Il y a même dans le manuel d’accompagnement 
(il est très complet et fait plus de cinquante 
pages) une section intitulée « Comment vendre 
votre aventure ». Elle donne de précieux 
conseils pour tester son programme et s’assurer 
qu’il ne comporte pas d’erreurs. Le plus utile : 
faire jouer le plus de gens possible et écouter 
leurs avis. Les créateurs de The Quill ne deman- 
dent pas de droits d’auteur, simplement une 
mention précisant que vous avez utilisé leur pro- 
gramme. C’est une manifestation d’altruisme 
assez rare dans ce monde qui veut des vedettes. 
Il s’agit de créer un jeu du type « Donjons 
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et dragons »; pourtant The Quill utilise des 
techniques assez proches de celles qui sont 
employées pour les bases de données nécessaires 
au traitement des problèmes de gestion. On dis- 
tingue trois parties fondamentales : la base de 


données elle-même, un éditeur (qui permet la 
mise en œuvre des paramètres) et un interpré- 
teur, qui permet une exécution interactive du 
jeu. 

Il est d’usage de fixer une limite au nombre 
d’objets que le joueur peut transporter d’un 


endroit à l’autre. Le jeu est bien plus intéres- 
sant : il faut parfois aller et venir avant de pou- 
voir disposer de tout ce dont on aura besoin 
pour accomplir les tâches qu’impose le déroule- 
ment de l'intrigue; l’ingéniosité du program- 
meur peut se donner libre cours. 

Pour mettre au point un jeu d’aventures, il 
faut d’abord rédiger un synopsis, élaborer un 
scénario et parfois dessiner une carte des lieux. 
Le manuel qui accompagne The Quill com- 
mence par présenter un jeu très simple, dans 
lequel le joueur a le choix entre dix objets répar- 
tis dans six pièces différentes. Astucieusement, 
ce jeu n’est pas intégré au programme lui- 
même : il vous faudra taper au clavier tous les 
paramètres, comme vous devrez le faire en 
créant votre propre histoire. 

Le nombre de paramètres utilisables est natu- 
rellement limité, mais il est si grand (252 lieux et 
210 objets) que vous ne serez sans doute jamais 
à court de possibilités. 

Tournant sur Spectrum et sur Commodore 64, 
The Quill permet la création de jeux d’aventures 
qui ne le cèdent en rien à ceux qu’on trouve 
dans le commerce — et quelques-uns de ces 
derniers ont d’ailleurs été composés grâce à 
lui, comme ce jeu qui met en scène le mari de 
Mne Thatcher.… Certaines restrictions n’en sont 
que plus regrettables. C’est ainsi qu’il n’est pas 
possible d’y intégrer le graphisme ni d’obtenir 
une certaine interaction entre les personnages, 
ce qui rend difficile de les doter d’une vie 
propre. 


Choix d'objet 

The Quill permet aux 
passionnés de créer leurs 
propres jeux d'aventures. 
Ce programme est assez 
semblable à certains 


logiciels de gestion ayant à 


traiter des bases de 
données. Il faut d’abord 
définir les lieux et les 
objets nécessaires au 
scénario. Des programmes 
objets permettent alors 


l'appel et l'affichage de ces 


attributs, ou leur emploi 


comme paramètres, chaque 


fois que le déroulement 
de l'intrigue nécessite 
leur apparition. 

(CI. lan McKinnell.) 


Etat d'âme 


La famille des microprocesseurs 68000 de Motorola est apparue 
sur le marché en 1982. C’est le successeur de grande capacité 
du célèbre microprocesseur sur 8 bits, le 6809. 


Le 68000 ressemble beaucoup au MC6800 qui 
est antérieur et toujours très répandu, notam- 
ment pour les périphériques tels que les contrô- 
leurs évolués. Cela signifie que le plus puissant 
68000 est simple à interfacer et dispose d’une 
compatibilité étendue avec de nombreux maté- 
riels. Parmi ceux-ci, des cartes entrée-sortie 
avec composants 6821 PIA (Perigheral Inter- 
face Adaptator, « adaptateur interface périphé- 
rique »), des unités de visualisation avec tubes 
6845 CTRC (Cathode Ray Tube Controllers, 
« contrôleurs de tubes cathodiques »), des hor- 
loges avec rythmeurs programmables 6840 et 
des contrôleurs disque. 

Le 68000 a également pour attrait d’offrir 
aux constructeurs une large gamme de bus de 
données et d’adresse. Ces derniers sont entière- 
ment distincts les uns des autres, et chaque bit a 
sa propre broche — contrairement aux 8086, 
8088 et Z8000, pour lesquels les broches sont 
multiplexées, les deux bus se partageant un jeu 
de broches. Les signaux sont séparés et décodés 
une fois arrivés à destination. 

Aussi le processeur 68000 peut-il travailler 
aussi vite que le permet le système. Avec les 
nouveaux composants de RAM fonctionnant à 
50 ou à 90 nanosecondes, cela peut aller jusqu’à 
supprimer les temps d’attente. Le microproces- 
seur le plus rapide de la famille des 68000 est le 
68000L12 dont plusieurs opérations peuvent se 
faire à 14 MHz. 

Sinclair a utilisé pour le QL le 68008, qui est 
le successeur du 68000. Il est, de manière 
interne, très semblable aux processeurs de la 
même famille, mais il est compatible avec les 
systèmes existants sur 8 bits, le bus de données 
étant sur 8 bits au lieu de 16. Du fait qu’il néces- 
site moins de broches, il n’en comporte que 
quarante. 

Motorola doit prochainement produire un 
microprocesseur encore plus puissant, sur 32 
bits, le 68020, qui sera sur quatre-vingt-seize 
broches. Le 68881 est un processeur de calcul 
mathématique de la virgule flottante, sur huit 
registres de 80 bits chacun. Il accroîtra considé- 
rablement la quantité de données effectivement 
traitées. 

Beaucoup d’autres composants de la famille 
des 68000 comportent des fonctions d’entrée- 
sortie améliorant les performances de leurs pré- 
décesseurs. Du point de vue du programmeur, 
le 68000 présente de nombreux avantages par 
rapport aux autres processeurs 16 bits. Ces 
avantages sont dus à la symétrie des registres de 


Processeurs vedettes 


registres est un de ses 
points forts. Il existe un 
seul accumulateur, mais 
l'ensemble de la page 
mémoire 0 peut servir à des 
registres d'utilisation 
générale. 


composants 
famille 6502-6800, et est 
construit autour de huit 
registres de données à 

32 bits, et de sept registres 
d'adresse également à 

32 bits. 


données et des registres d’adresse, et à la 
richesse du jeu d’instructions. 

Cela dit, le 68000 n’est pas pour autant par- 
fait. D’abord il y a cette distinction entre les 
deux types de registres, alors qu’ils sont de la 
même taille (32 bits) et sont gérés de manière 
similaire par les mêmes instructions. Le résultat 
est qu’il est souvent nécessaire de déplacer des 
données depuis un registre d’adresse sur un 
registre de données, les traiter, et les remettre 
sur le registre d’adresse. Cela aurait été plus 
facile si Motorola avait fait les registres aussi 
bien pour les données que pour les adresses. 

Ensuite, certaines instructions se recoupent. 
Ce n’est pas grave puisque cela résulte des 
modes d’adressage se recoupant eux-mêmes. 
L’explication est la suivante : souvent très diffé- 
rents, ces modes d’adressage aboutissent au 
même résultat. 

De manière générale, les microprocesseurs de 
la famille 68000 font des unités centrales de 
grande capacité, rapides et efficaces, et de plus 
en plus répandues. Le 68000 équipe le Lisa et le 
Mackintosh d’Apple, le QL de Sinclair et de 
nombreuses autres machines de gestion. Le 
68000 offre, à un coût raisonnable, des ressour- 
ces qui auraient coûté une fortune il y a seule- 
ment quelques années. La famille des 68000 ren- 
contre autant de succès que le Z80 ou le 6502. 


base de la 


Son jeu d'instructions 
est également beaucoup 
plus étendu. Son atout 
principal par rapport au 
6502 a sans doute été 
d'être compatible avec le 
système d'exploitation 
CP/M. (CI. Kevin Jones.) 
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Les micro-ordinateurs et la haute- 
fidélité ont bien des choses en 
commun. Cette série d’articles 
permettra au débutant d’effectuer 
lui-même certains petits travaux, 
qui, autrement, se révéleraient très 


onéreux. Aujourd’hui : la soudure. 


La soudure, comme le brasage, consiste à join- 
dre, grâce à un alliage métallique aisément fusi- 
ble (en électronique, on utilise le plomb et 
l’étain), deux objets de métal, que l’on chauffe 
d’abord à une température supérieure au point 
de fusion de cet alliage (280 °C), que l’on étale 
ensuite sur eux. Puis on les met en contact, et on 
interrompt le chauffage. 

Un fer à souder mis au contact d’un fil 
d’alliage le fait fondre presque aussitôt. Toute- 
fois, si le métal en fusion est déposé sur des piè- 
ces à joindre restées froides, il se solidifiera 
presque instantanément. C’est ce qu’on appelle 
une soudure « sèche ». Au mieux, elle ne tiendra 
pas. Au pire, elle ne donne qu’une connexion 
très médiocre, qui pourra même ne laisser pas- 
ser le courant électrique que par à-coups. Un 
seul moyen d'empêcher cela : chauffer d’abord 
les deux pièces, jusqu’à ce que le fil à souder 
fonde par simple contact. 


Plusieurs fers au feu 

Il faut d'abord se souvenir 
que les composants 
électroniques sont très 
sensibles à la surchauffe. 
On en tiendra compte en 
choisissant un fer à souder 
(dimension de la pointe 
chauffante, diamètre du fil 
à souder). De façon 
générale — ainsi pour des 
raccords électriques ou de 
simples connexions — ce 
problème est cependant 
moins important. Un fer à 
souder de 15 ou 25 W et un 
fil d'alliage de 1,5 mm de 
diamètre se révéleront 
adaptés à la plupart des 
tâches. 


Une bonne prise 


Si les micr&ordinateurs font désormais partie de 
notre vie quotidienne, c'est aussi à cause de leur 
taille réduite. Leurs composants sont minuscules et 
les manipuler est parfois difficile. Des pinces et des 
étaux légers, de prix raisonnables, vous y aideront. 
Si vous trouvez la prise insuffisante, servez-vous de 
chatterton. (CI. lan McKinnell.) 


Ne pas perdre le fil 

Chaque fois qu'on a affaire 
à des fils électriques, il faut 
d'abord les dénuder, puis, 
le travail accompli, les 
recouvrir de façon nette et 
propre. Une pince à dénuder 
comme celle-ci est très bon 
marché; on peut la régler 
pour qu'elle ne morde que 
jusqu'à une certaine 
profondeur. 
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Dénudage et étamage 
Lorsqu'on veut raccorder une fiche et un fil électrique, 
il faut d'abord dénuder celui-ci en enlevant la gaine 
isolante. Voyez large et sectionnez plus de gaine qu'il 
n'est nécessaire; une fois l'opération terminée, 

vous supprimerez toute longueur de fil superflue. 
Maintenez le câble électrique dans l’étau, chauffez-le 
avec le fer, et appliquez-y la soudure. Quand elle 
commence à fondre, étendez-la proprement, à l'aide 
du fer, sur toute la surface dénudée. Ce procédé 
s'appelle l'étamage, et simplifie considérablement 

la soudure elle-même, puisque le composant fusible 
est désormais réparti sur les pièces à joindre. 
Répétez l'opération sur la fiche elle-même. Pendant 
qu'elle est encore assez chaude pour faire fondre le 
fil à souder, appliquez sur elle le cäble étamé, retirez 
le fer dès que l’alliage commence à unir les deux 
éléments, soufflez pour refroidir et le tour est joué! 


Un tournevis adapté Les pinces également servir à couper 

On distingue deux variétés Le débutant peut se les fils électriques; et la 

de tournevis : plat et satisfaire de deux modèles pince à long bec (en haut), 

cruciforme. Ce dernier différents : la pince irremplaçable quand on doit 

comprend d'ailleurs deux universelle (ci-dessus), accomplir des tâches Ébarbage 5 

modèles, mais ils sont indispensable pour tous les plus délicates. Il faut mainterfänt ébarber tout élément superflu. Cela 
utilisés indifféremment sur travaux en force et qui peut (CI. Michael Brownlow.) est valable aussi ‘bien pour le fil que pour les broches 


de la fiche elle-même : mais il faut s'y prendre au tout 
dernier moment, c'est-à-dire lorsque le raccord a été 
testé. L'ébarbage est indispensable : fil ou broche 
peuvent en effet entrer en contact avec un autre 
composant, provoquant un court-circuit ou, 

pis encore, une de ces pannes re otohiet 

si exaspérantes. (CI. Kevin Jones.) 


la plupart des micro- 
ordinateurs. Sans doute 
aurez-vous besoin des uns 
et des autres, dans des 
tailles différentes. 


Petites coupures 

Pour couper des fils 
électriques on emploie des 
pinces comme celle-ci, ou 
un modèle un peu différent, 
dont les mâchoires sont 
perpendiculaires au plan 
des poignées. En cas 
d'urgence, vous pourrez 
toujours utiliser un coupe- 
ongles, mais n'espérez pas 
pouvoir vous en servir 
encore par la suite. 
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Formes simplifiées 


La simplification de l’algèbre de Boole suppose l’écriture 
d’expressions avec moins d’opérateurs (ET, OÙ, et NON). 
C’est important pour concevoir de longs circuits logiques. 


Les diagrammes de Venn fournissent une aide 
graphique appréciable pour simplifier les 
expressions booléennes, dans la mesure où elles 
les visualisent. La zone comprise dans un rec- 
tangle (symbolisée par 1 = identité ou ensemble 
universel) représente toutes les combinaisons 
possibles pour les valeurs vraies en données; les 
cercles représentent certaines combinaisons pos- 
sibles. Voici des exemples de diagrammes de 
Venn ci-dessous. 

La comparaison entre les diagrammes 5 et 7 
montre d’un seul coup d’œil que NON(A OU B) 
est différent de NON(A) ou NON(B). Pareille- 
ment, les diagrammes 6 et 8 montrent que 
NON(A ET B) est différent de NON(A) ET 
NON(B). 


> 
œ 


N 


OX 


CL 


4 
PTS 


Se 


N\ 


CC 


RR 


AN 


Z 


La At la plus 235 de à ee. 


ET et OÙ est de penser à A.B comme à l’inter- 
section de À et de B, et de penser à À + B 


NN 
NN 


comme à la fusion de A et de B. Il existe des 
relations évidentes en algèbre de Boole. Vous 
pouvez pour chacune d’elles tracer un dia- 
gramme de Venn pour les vérifier (0 représente 
l’ensemble vide, c’est-à-dire une combinaison 
impossible). 


1° A.A. = A 
2 AA, =70 
3° A.0 = 0 
4° A.1 = A 


5° A.(A + B) = A 
6° A.(A + B) = A.B 


Lois d’algèbre booléenne 


Le concept de dualité est très utile et. curieux! 
Il est fondé sur la symétrie des opérateurs ET et 
OÙ. Pour écrire le double d’une relation vraie, 
il suffit d’inverser tous les OU et les ET, les 0 et 
les 1. Prenons par exemple la cinquième opéra- 
tion de la liste plus haut : A.(A + B) = A. Le 
double en est : A + A.B = A. Cette expression 
est également vraie. Elle illustre un autre prin- 
cipe important de l’algèbre booléenne, le 
principe d’absorption. En regardant le dia- 
gramme de Venn pour cette expression, il est en 
effet évident que le terme A.B est entièrement 
« absorbé » par A. Ce principe peut être étendu 
à un exemple sur trois variables tel que : A.B + 
A.B.C. = A.B. Les deux diagrammes de Venn 
suivants confirment cette règle. 


C C 
A.B A.B.C 


Alison Fenton 


Vous pouvez vous exercer à écrire les doubles 
des cinq autres relations spéciales, et à tracer 
leur diagramme pour en confirmer la validité. 

Examinons à nouveau les diagrammes donnés 
plus haut. Les diagrammes 5 et 8 montrent que 
la relation suivante est toujours vraie : À + B 
— A.B. La comparaison des diagrammes 6 et 
7 met en évidence la relation suivante : A.B = 
A + B. Ces deux relations sont appelées lois de 
Morgan. Elles sont applicables à des expres- 


sions plus complexes, à trois variables, par 
exemple : À + B + C = A.B.C et A.B.C = 
A+B+cC. 

Les lois de Morgan peuvent également 
s’appliquer par étapes : 

(A + B).C 

= A.B.C (selon la loi de Morgan 
sur les parenthèses) 


— À + B + C (selon l’utilisation recombinée 
de la loi de Morgan). 


Il existe trois règles communes à l’algèbre 
normale et à l’algèbre de Boole. La loi associa- 
tive permet de supprimer des parenthèses : 

(A5B):C = ABC) = "ABC 

(A+B+C=A+(B+C=A+B+C 

L'ordre d’écriture peut être changé en vertu 
de la loi commutative : 

A.B = B.A 

A + B=B + A 

La loi distributive permet de « distribuer » 
une opération : 

A.(B + C) = A.B + A.C 


Exemples de simplification 
1° Simplifier (À + B + A.B).B 

= (A.B + A.B).B (loi de Morgan) 

= A.B.B. + A.B.B (loi distributive) 
0 + A.B (B.B. = 0et BB = B) 

= A.B 
2° Simplifier A.B. + A.B + A.B 
= A.(B + B) + A.B (loi distributive) 
À + A.B(B + B = 1) 
À + B (double de la relation 6). 
3° Simplifier À + B + À + B + À + B 
A.B + A.B + A.B (loi de Morgan) 
A.B + A.B + A.B (A = A) 
A.(B + B) + A.B (loi distributive) 
A + AB(B + B = 1) 
— À + B (double de la relation 6). 


Porte logique XOU simplifiée 
Nous avons vu dans le dernier numéro le circuit 
complet pour une porte logique XOU (OU 
exclusif). Reprenons-le : 

ENTRÉE SORTIE 


Nous avons déduit de la table que C = A.B 
+ A.B. Il n’est pas possible de simplifier de 


manière significative cette expression, et un cir- 
cuit à cinq portes logiques serait nécessaire pour 
l’implémenter. Mais il existe un autre moyen : 
C peut être considéré comme égal à 1 si A et B 
ne sont pas ensemble respectivement 1 ou 0. 
Nous pouvons écrire C en algèbre booléenne : 


C = A.B + A.B 


En utilisant plusieurs fois les lois de Morgan, 
nous pouvons simplifier le circuit : 


C = (A.B).(A.B) 
et finalement : 
C = A.B.(A + B) 


Cette expression ne prend que quatre portes 
logiques : 


Liz Dixon 


Un circuit additionneur complet 


Nous avons déjà abordé l’addition binaire et 
élaboré un circuit simple destiné à additionner 
deux bits et à produire deux résultats, pour la 
somme et pour la retenue. Il s’agissait d’un cir- 
cuit « demi-additionneur ». Si nous appelons X 
et Y respectivement la première et la deuxième 
entrée, nous pouvons vérifier d’après la table de 
vérité pour ce type de circuit que le résultat (la 
somme) peut s’écrire sous la forme de l’expres- 
sion suivante : S = X.Y + X.Y. Après simplifi- 
cation par les lois de Morgan : S = X.Y(X + Y). 
La retenue est simplement : C = X.Y. 

En arithmétique binaire, il y a trois chiffres à 
additionner, et donc trois colonnes pour la 
somme. Outre les deux chiffres à additionner, il 
y a la retenue de la colonne précédente. Pour 
reproduire le processus d’addition binaire, il 
faut concevoir un circuit à trois entrées et deux 
sorties. Si nous appelons la retenue de la 
colonne précédente P, la table de vérité pour un 
circuit additionneur complet sera : 

ENTRÉES SORTIES 


En prenant le cas où S = 1, il est possible 
d'établir une expression pour S à partir de la 
table de vérité : 

S = P.X.Y + P.X.Y + P.X.Y + P.X.Y 

Expression simplifiable : 

S = R(X.Y + X.Y) + P.(X.Y + X.Y) 

[loi distributive] 

S = P.(X.Y + X.Y) + P.(X.Y + X.Y) 

[loi de Morgan] 

De manière similaire, nous pouvons écrire 
une expression pour C à partir de la table de 
vérité : 

C = P.X.Y + P.X.Y + P 

C= XY:E + Pl) PCA 

[loi distributive] 

C=XY+PIXY FX YT) 

P+P=1) 


On remarque que X.Y + X.Y est ie résultat 
de la somme selon un circuit demi- 
additionneur. Il est ainsi possible de créer un 
circuit additionneur complet à partir de deux 
circuits demi-additionneurs. 


EXERCICE 3 


1° Simplifier les expressions suivantes : 


a) A(A + Ë) à 

b) X + YAX + Y) + X{X + Y) 

c) P.Q + P.Q + PQ 

D'UN EUVZ EIZN 

2° Un système d'alarme de voiture comporte un 
commutateur et un détecteur sur les deux portes 
avant. La sirène d'alarme se déclenchera si l’on 
cherche à ouvrir l’une des deux portes (ou les 
deux) lorsque le système est commuté (branché). 
Tracez une table de vérité qui indique les trois 
entrées de données (la porte À, la porte B, le 
commutateur du système), et la sortie logique 
du circuit, le déclenchement ou le non- 
déclenchement de l'alarme. Utilisez cette table 
pour écrire une expression booléenne pour le 
déclenchement de l'alarme, et tracez le circuit 
logique du système d'alarme. 


3° La lumière d’un escalier se commande 
depuis un commutateur à l'entrée, un autre au 
bas de l'escalier, et un troisième en haut. 
Réalisez un circuit logique approprié. 


4° Vous êtes abandonné sur une île déserte 
avec deux autres personnes. L'une d'elles dit 
toujours la vérité, l’autre ment toujours. Pour 
votre survie, il faut absolument que vous sachiez 
laquelle dit la vérité. Pour y parvenir, vous devez 
imaginer des questions qui démasqueront le 
menteur. Tracez des tables de vérité pour 
envisager les réponses possibles selon la 
personne à laquelle les questions s'adressent. 
Voici un exemple : 

« Dites-vous toujours la vérité? » 


pérmseossine 
__ OU NON 


IDENTITÉ 
POSSIBLE 
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X.Y + P(XY + XY) 


c 
Demi- 
addi- 
tionneur 


S Cc 
Demi- 
addi- 


tionneur 


s S = P(XY + XY) + P(XY + XY) 


L'exemple suivant indique comment huit circuits additionneurs complets 
se combinent dans le cadre de l’unité arithmétique et logique, pour effec- 
tuer l’addition binaire de deux nombres sur 8 bits : 


pe 


Réponses à l’exercice 2 
1° 


1°" nombre 


Be 


A A+B 


(A + B).C 


à. A.B + (A +B) 


(A + B).(B.C + C) 
+ B 


Labyrinthes 


Avec les batailles spatiales, les jeux de labyrinthes sont également 
très prisés par le grand public. Rappelez-vous du succès de PacMan! 


En voici quatre autres. 
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SPECTRUM BRAIN DAMAGE 


C'est un jeu d’oracle qui se passe dans un labyrinthe 
et dont le principe de base est de tuer vos ennemis 
avant qu'ils ne vous tuent eux-mêmes. Vos adver- 
saires sont le Panzer électronique, le Centurion et le 
Maraudeur, qui peuvent tirer dans toutes les direc- 
tions et souvent avec des effets très dévastateurs 
pour votre propre tank. 

Les graphiques ne sont pas de très bonne qualité, 
mais les effets sonores sont intéressants. 


VIC-20 BEWITCHED 


C'est un produit de la Société Imagine qui est très 
attractif. Le jeu consiste en un voyage dans un laby- 
rinthe qui comporte des portes à serrures. 

L'écran représente le labyrinthe divisé en trois sec- 
tions. Les sections inférieures sont bloquées par 
quatre portes de couleurs différentes, fermées à clef 
et qui ne peuvent être ouvertes que par des clefs de 
même couleur qui se trouvent dans la première partie 
du labyrinthe, en haut de l'écran. 


BBC FELIX AND THE FRUIT MONSTERS 


Un labyrinthe relativement simple, dans le genre clas- 
sique de PacMan. || y a des pilules énergétiques dans 
des coins du labyrinthe qui vous permettent d'esqui- 
ver les monstres qui essaient de vous attraper, mais 
au lieu de les manger comme dans un PacMan clas- 
sique, il faut déplacer les fruits autour du labyrinthe 
en n’en transportant qu’un seul à la fois. Un jeu 
moyen, dans l’ensemble, qui présente un défaut 
majeur à signaler le concepteur n'a pas prévu 
d'option de changement des touches de contrôle, ce 
qui peut être très gênant! 


ATARI WAY OUT 


Un jeu de labyrinthe extrêmement attractif par ses 
effets visuels et sonores et par les simulations en 
trois dimensions très bien réussies. On peut se dépla- 
cer dans 26 labyrinthes différents, dont la liste est 
affichée au début du jeu et que l’on sélectionne par 
un code. Le joueur dispose d'un compas pour se diri- 
ger et d’un plan général du labyrinthe pour le choix 
d'une direction. Mais chacun des labyrinthes est 
habité par le « cleptangle », entité mystérieuse qui 
ressemble étrangement à la fameuse « dalle noire » 
de 2001, l'Odyssée de l'espace. 


Jeux EE 
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Jusqu'au 
bout 


Peu de constructeurs 
d'ordinateurs espèrent vendre 
un million d'exemplaires d’un 
modèle donné; c’est ce que 
Sinclair a fait avec le Spectrum. 
Celui-ci en est actuellement à 
sa troisième version. 


S’agissant de la construction elle-même, c’est 
avant tout le clavier que l’on remarque. Il est 
bel et bien de type QWERTY, mais les ressem- 
blances avec une machine à écrire s’arrêtent là. 
Chacune des quarante touches repose sur une 
membrane, qui donne à la frappe un certain 
jeu; l’ensemble paraît mou et même « spon- 
gieux ». 

Un bus d’extension permet au Spectrum de se 
raccorder à l’imprimante ZX (prévue à l’origine 
pour le ZX-81), aux interfaces ZX 1 ou 2, ou 
aux trois en même temps. Il existe aussi des 
prises EAR et MIC qui permettent l’enregistre- 
ment des programmes sur cassette. Le char- 
gement des logiciels n’est guère satisfaisant. 
Ces deux opérations, une fois achevées sans 
encombre, entraînent l’apparition, en bordure 
d’écran, de lignes bleues et jaunes peu rassuran- 
tes; mais l’enregistrement, par exemple, néces- 
site d’abord la mise hors service de la prise 
EAR. Il n’existe pas non plus de bouton de 
remise à zéro, ce qui implique qu’en cas de blo- 
cage ou de « plantage » du système il faut cou- 
per le courant, ce qui peut à la longue se révéler 
mauvais pour les connexions. Heureusement, 
un certain nombre de firmes indépendantes 
fournissent des dispositifs (interrupteurs Save 
or Load et Reset) qui résolvent ces problèmes. 

Sinclair Research paraît, là comme ailleurs, 
avoir été largement distancé par d’autres; mais 
c’est une politique qui semble délibérée : négli- 
geant les petits problèmes de maintenance, la 
firme, grâce aux profits que lui ont valu les 
ventes, peut se consacrer à d’autres produits, 
comme le QL. Elle a d’ailleurs, malgré tout, mis 
au point les Microdrive et l’interface ZX 1, qui 
permettaient d’obtenir une capacité de mémoire 
théorique de 680 K, de relier en réseau soixante- 
quatre Spectrum et d’employer un port RS232. 
Il y a eu depuis l’interface ZX 2, qui autorise le 
raccord de deux manches à balai, et l’accès aux 
logiciels inscrits en ROM. 


Sinclair Research semble également avoir 
abandonné à autrui la production de logiciels, 
et se borne à donner sa garantie, sous forme 
d’approbation officielle. 
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QUAU UUUUEREURNEE 


Demandez les programmes 
ar - — Il existe de très nombreux 
} jeux destinés au Spectrum, 


A 
PEXYLLLELT. 
c 


| 
mais aussi un assez grand 
« f: nombre de programmes de 
un | Le url gestion (financière ou 
= { | | | familiale). Ils sont vendus à 


br x 


EME des prix généralement très 
| - raisonnables. Avec 
l'apparition des Microdrive, 
2 : il est désormais tout à fait 
, 3 pi possible de faire tourner 
ÈS 7 — sur Spectrum d'importantes 
RL - bases de données, des 
«| , »! : nus, tableurs ou des logiciels de 
| “ M | F traitement de texte. 
| 4 F7 Psion, un des plus proches 
| Ge. U n |f collaborateurs de Sinclair 
2} ETES) 5 . Research pour ce qui est de 
TT Eh ae TÜ l'élaboration des 


programmes, est la firme à 
qui on doit nombre de ces 
logiciels. Elle a ainsi lancé 
une série qui a eu 
beaucoup de succès : 
VU-CALC, VU-File, VU-3D. 
La compagnie Microl a, en 
dépit de la médiocrité du 
[ clavier du Spectrum, mis 
û sur le marché The Word 
al. Processor, qui permet de 
stocker jusqu'à dix pages 
de texte, et qui offre bien 
des particularités 
d'habitude réservées aux 
traitements de texte plus 
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Lecteur de disque 
Commodore 

Disponible sur le VIC-20 et 
sur le Commodore 64, et 
prévu en série pour le futur 
ordinateur portable SX 64, 
le lecteur 1540 est du type 
« intelligent », qui ne 
dépend pas de l'unité 
centrale où de sa mémoire. 
ll comporte son propre 
microprocesseur : le 
système d'exploitation 
mémoire 6502 qui équipe 
les ordinateurs eux-mêmes. 
(CI. lan McKinnell.) 


Commandes de disque 


Commodore fabrique depuis plusieurs années toute une gamme de 
lecteurs 5 pouces. Ils sont tous « intelligents », et comportent donc 
leur propre microprocesseur et leur mémoire vive (RAM) associée. 


Le problème essentiel des lecteurs dits « intelli- 
gents » est leur coût. Après le lancement du 
micro-ordinateur Vic-20, Commodore proposa 
une version bon marché de ses lecteurs célèbres, 
PET, sous la forme d’un lecteur à une dis- 
quette, le Vic-1540. Le Commodore 64 a les 
mêmes caractéristiques, quant à l’accès, que le 
lecteur 1540. Cependant, certaines différences 
ont rendu nécessaire l’emploi d’une commande 
POKE avant et après l’utilisation. Le remplace- 
ment du lecteur 1540 par le lecteur 1541 a per- 
mis d’éliminer cet inconvénient par la modifica- 
tion du système d’exploitation. Cette nouvelle 
version est compatible avec le Vic-20 et le Com- 
modore 64. Pour des raisons de commodité, 
nous nous référerons aux deux lecteurs en par- 
tant du même nom, 1541. 

Le contrôle du 1541 passe par un micropro- 
cesseur 6502, deux adaptateurs interface poly- 
valents 6522, une mémoire vive de 2 K et une 
mémoire morte de 8 K qui contient le micropro- 
cesseur. Ce dernier est très puissant et permet de 
programmer des routines complexes de gestion 
de fichiers programmes, de fichiers séquentiels 
et indexés, avec des procédures de gestion 
d’erreurs sophistiquées. Le contrôle de l’ordina- 
teur est assuré par une version série de l’inter- 
face IEEE488. Celle-ci comporte les mêmes 


L'unité de microprocesseur 6502 


Contrôle le formatage et le 
positionnement de la tête 
de lecture, ainsi que la 
transmission des données 
par l'intermédiaire dè 
tampons mémoire. 


Disquette 
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Contrôle les 
communications entre 
l'ordinateur et les lecteurs. 


Mémoire morte 
Ce composant contient le 
système d'exploitation. 


Alimentation 
Les lecteurs 1540 comportent 
leur propre alimentation. 


commandes que son puissant équivalent paral- 
lèle qui contrôle les autres périphériques Com- 
modore. En outre, l’interface série IEEE488 
permet le chaînage en marguerite des interfaces. 
Ainsi, un lecteur de disque peut transmettre des 
fichiers en impression pendant que l’ordinateur 
effectue d’autres tâches. Cela s’obtient par des 
commandes associées avec des numéros appro- 
priés de fichiers logiques et d’unités de disque. 

Les disquettes sont formatées sur 35 pistes sur 
une seule face et chaque face comporte des sec- 
teurs (21 secteurs pour la piste la plus externe et 
17 pour la piste la plus interne). Chaque secteur 
comporte un bloc de données de 256 octets avec 
en plus des données portant sur la synchronisa- 
tion, le nom et le bit de parité (vérification). 

Une disquette permet de stocker 683 blocs, 
dont 664 sont disponibles pour l’utilisateur. Ce 
qui donne une capacité maximale de 170 K 
approximativement, selon le type de fichier. Le 
système d’exploitation gère la répartition des 
données par une carte de disponibilité des blocs 
et un répertoire. La carte est sur le secteur 0 de 
la piste 18 et comporte 144 octets. Elle indique 
les blocs utilisés et les blocs disponibles. Le 
répertoire commence sur le secteur 1 de la 
piste 18 et comprend une liste maximale de 
144 fichiers répartis par leur nom. Ce dernier 
indique le type du fichier et son nombre de 
blocs. À chaque mouvement de données, la 
carte de disponibilité des blocs et le répertoire 
sont mis à jour. 

Malgré son prix d’achat élevé, la souplesse 
d'utilisation du système de lecteur de disque 
Commodore en fait un investissement justifié. 
Le stockage en mémoire de masse qu’il permet 
peut être incorporé à un système de gestion des 
périphériques et ne pèse pas sur la mémoire de 
l’ordinateur ou sur le minutage du processeur. 
Cependant, du fait de l’interface série, le lecteur 
1541 est relativement lent. Commodore n’indi- 
que même pas une vitesse de transmission des 
données ou un temps d’accès moyen. Bien que 
la vitesse de stockage soit cinquante fois supé- 
rieure à celle d’une unité de cassette, le lecteur 
1541 est vraisemblablement le plus lent des lec- 
teurs pour ce qui est de l’accès. Si une grande 
capacité de stockage est nécessaire, une inter- 
face connectable sur le port série peut être ache- 
tée, qui imitera le port parallèle des micros de 
type PET. Cela n’accélère pas particulièrement 
les opérations, mais vous permet de connecter 
tous les périphériques PET sur un Vic-20 ou un 
Commodore 64. 


Les commandes disque 
du Commodore 


Le système d'exploitation du Commodore com- 
porte une large gamme de commandes d'’élabo- 
ration de programmes de gestion de fichiers 
indexés, en dehors des procédures habituelles de 
gestion de programme et de données. Ces com- 
mandes s'utilisent de la manière indiquée 
ci-dessous. Pour chaque cas, 8 est le numéro de 
lecteur. 


SAVE 

Crée des fichiers programme dont le nom porte 
sur seize caractères, et qui peuvent comporter 
soit des programmes soit des données. 

La syntaxe est la suivante : 


SAVE « NOM DU FICHIER », 8 


LOAD 
De syntaxe : 


LOAD « NOM OÙ FICHIER », 8 

Copie le fichier programme spécifié, en mémoire 
vive, depuis les positions de poids faible. La com- 
mande. 


LOAD « NOM DU FICHIER » 8, 1 


recopie le fichier indiqué sur les positions 
mémoire dont il avait été sorti par SAVE. 


LOAD « S », 8 


Copie le répertoire disque en mémoire utilisateur. 
Il peut ensuite être listé (LIST) comme un pro- 
gramme Basic, et il contient : 

— nom du disque; 

— identificateur disque sur deux caractères; 

— maximum de 144 noms de fichiers; 

— fichiers de type programme ou séquentiel; 

— longueur en blocs pour chaque fichier; 

— nombre de blocs disponibles. 


VERIFY 
De syntaxe : 


VERIFY « NOM DU FICHIER », 8 


Compare le contenu du fichier avec celui du 
fichier couramment contenu en mémoire utilisa- 
teur. Génère un message d'erreur s'ils sont diffé- 
rents. Est utilisé pour vérifier si les fichiers ont été 
sauvegardés (SAVE) convenablement. 


OPEN 

Établit un canal dit « numéro de fichier logique », 
compris entre 1 et 255. Il est possible d'ouvrir 
jusqu'à dix numéros de fichiers logiques en même 
temps. OPEN crée également une adresse secon- 
daire qui détermine le mode d'action du périphéri- 
que. La seule adresse secondaire pour un lecteur 
est 15. Elle donne accès au canal prioritaire “com 
mand”. La syntaxe d'OPEN est la suivante : 


OPEN LFN, 8, SA 


CLOSE 
De syntaxe : 


CLOSE LFN 


Ferme le fichier logique spécifié. Les fichiers 
logiques doivent toujours être fermés quand on 
n’a plus besoin d'eux. 


PRINT %, INPUT AND GET = 

PRINT # fonctionne de la même manière que PHINI, à 
la différence près que les données sont sorties 
sous la forme d'un fichier séquentiel, vers le 


fichier logique OPEN, plutôt que vers l'écran. De 
syntaxe : 


PRINT # LAN, « DATA » ou 
PRINT % LEN, A$, B$... 


De la même manière, INPUT % et GET * acceptent en 
lecture des fichiers séquentiels. INPUT £ restitue des 
chaînes de données, mais ne sera efficace que si 
les chaînes sont séparées par des points-virgules 
ou par des virgules, faute de quoi les chaînes 
seraient considérées comme une seule chaîne. 
GET % restitue les données octet par octet, y com- 
pris les points-virgules et les virgules. Ce qui est 
très utile lorsque le contenu d'un fichier est 
inconnu ou ne comporte pas de séparateurs. Voici 
des exemples de syntaxes : 


INPUT £ LEN, A$, B$.. 
GET # LEN, À$, B$.. 


Lorsque PRINT % est utilisé en conjonction avec un 
fichier logique ouvert (OPEN) vers un canal de com- 
mande (c'est-à-dire OPENLEN, 8, 15), sous la forme sui- 
vante : 


PRINT # LEN, 8, 15, « chaine de commande » 


PRINT devient alors la commande gestion de dis- 
que la plus puissante possible. Les chaînes de 
commande servent à implémenter les commandes 
de maintenance de disque et les commandes de 
gestion de fichiers à accès direct (relatif, REL). 


Commandes de 
maintenance de disque 


Utilisées sur le canal de commande, avec PAINI : ou 
OPEN 5, et selon la syntaxe appropriée, elles ont les 
fonctions suivantes : 


NEW 

Formate et donne un nom à la disquette; établit la 
table de disponibilité de blocs, et le répertoire. 
Donne une valeur à l’identificateur de disque sur 
deux caractères; commande : « N : DISKNAME, D! » 


INITIALISÉ 

Ajuste la table de disponibilité des blocs présente 
en RAM disque avec celle qui se trouve sur le dis- 
que. 

Commande : «| » 


VALIDATÉ 

Supprime les blocs alloués par les commandes REL 
qui ne figurent pas au répertoire, ainsi que les 
fichiers non fermés (CLOSE) après avoir été écrits. 
Établit une nouvelle table de disponibilité des 
blocs. 

Commande : « V » 


RENAME 
Change le nom du répertoire d'un fichier. 
Commande : « R : NOUVEAU NOM - ANCIEN NOM » 


SCRATCH 

Supprime le fichier demandé du disque et du 
répertoire. 

« S : NOM OÙ FICHIER 1, NOM DU FICHIER 2, … » 


COPY 

Fait une copie du fichier demandé, sur le disque 
même. 

Commande : « C : NOM COPIE + NOM ORIGINE » 

Réunit les fichiers séquentiels en un seul et même 
fichier séquentiel sur le même disque, « conca- 
tène » les fichiers. 

Commande : « C : NOM CONCA - NOM 1, NOM 2, … » 


Vérification des erreurs 

Le panneau frontal du 
lecteur de disque 1541 
comporte une diode verte 

« lecteur allumé », et une 
diode rouge indiquant : 

+ On. lecture ou écriture en 
cours. 

+ Off. dans l'attente 
d'instructions. 

+ Clignotement. le système 
d'exploitation a détecté une 
erreur. 

Pour découvrir la nature de 
l'erreur, il faut lire le canal 
d'erreur du système 
d'exploitation. Le 
programme suivant imprime 
les codes d'erreur générés 
par le système 
d'exploitation. On les 
trouvera dans le manuel 
utilisateur. 
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ENTRE LES LIGNES 


N'oubliez pas de numéroter 
vos lignes par multiples de 
10. Même les meilleurs 
programmeurs se trouvent 
parfois obligés de faire des 
insertions entre les lignes. 
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L'ABC du BBC 


Nous poursuivons notre exposé du BASIC résident BBC. Ce langage 
est aussi riche que la machine elle-même, et son apparition sur 
le marché a été aussi décisive que celle du BBC. 


L'utilisation de ELSE dans l’instruction |F..THEN, 
sous la forme IF..THEN..ELSE, permet de supprimer 
la plupart des instructions G0TO. En effet, avec 
cette forme on peut traiter dans une même ins- 
truction l’état vrai ainsi que l’état faux de 
l'expression conditionnelle. 

Par exemple : 


500 IF TEST >0 THEN GOTO 1800 
600 PRINT « VALEUR HORS ÉCHELLE 
700 GOTO 1900 
800 PRINT « SANS PROBLÈME ) 
900 NEXT L 
pourra être avantageusement remplacé par : 
600 IF TEST >0 THEN PRINT « SANS PROBLEME » 


ELSE PRINT « VALEUR HORS ECHELLE » 
900 NEXT L 


GOSUB prend généralement un numéro de ligne 
pour argument. Cela présente deux inconvé- 
nients : d’abord (et prenons un exemple) GOSUB 
1000 ne donne aucune indication sur le sous- 
programme à la ligne 1000; ensuite, les renvois 
à des numéros de ligne rendent le programme 
difficile à lire et éventuellement à fusionner. 

GOSUB, comme GO0T0, est relativement lent à 
exécuter, du fait que la ligne spécifiée doit être 
cherchée à chaque occurrence de l’instruction. 

Le BASIC du micro-ordinateur BBC apporte 
des réponses à ces problèmes. Ses fonctions et 
procédures sont semblables à des blocs de code 
du genre sous-programme. Elles sont appelées 
par l'intermédiaire d’un nom au lieu d’un 
numéro de ligne. Aussi sont-elles suffisamment 
explicites en elles-mêmes. Les appels de fonc- 
tions et de procédures prennent un sens à la 
seule lecture du programme. Ils ne sont pas 
modifiés par la renumérotation ou par la fusion 
du programme avec un autre programme. En 
outre ils sont exécutés bien plus rapidement que 
GOSUB et GOTO. 

Les procédures et les fonctions commencent 
respectivement par DEF PROC et DEF FN. Elles com- 
portent généralement une liste de paramètres. 
Par exemple (avec calc pour « calcul » et trait pour 
« traitement ») : 


1200 DEF FNcalcla,b,c) = la-bl*c/1000 et 
2500 DEF PROCtraitiw,x$,y$,2l 


Les définitions prennent ces paramètres pour 
des variables du programme. Cependant, lors 
de l’appel des fonctions ou des procédures par 
le programme, ces paramètres peuvent être rem- 
placés par tout numéro de variable ou par toute 


expression littérale de même type de données 
que le paramètre originel. 
Par exemple : 


250 result = FNcalc (prix, coût, 12) ou 
545 PROCtrait (6, noms$, « dupont », tableau {121} 


Les valeurs des paramètres sont ensuite utili- 
sées à la place des variables virtuelles dans la 
définition. Vous remarquerez qu’une fonction 
peut être mise dans une expression en tant que 
variable ou quantité arithmétique, alors qu’un 
appel de procédure doit être utilisé comme une 
commande BASIC. La commande LOCAL, qui 
définit des variables à n’utiliser que dans le bloc 
de définition, supprime le risque d’erreur sur le 
sous-programme. Soit le code : 


100 FOR K = 1 TO 10:GOSUB 500:NEXT K:END 
500 FOR K = 1 TO 5: PRINT« **** »:NEXT:RETURN 


La variable K est ici utilisée comme compteur 
de boucles à la ligne 100 du programme princi- 
pal, et à nouveau au sous-programme de la ligne 
500. C’est là un enchaînement dangereux car 
trop éloigné, et qui ralentira l’exécution. Mais 
c’est un mal nécessaire dans la mesure où en 
BASIC classique comme ici, il sera très difficile à 
éviter, ou à examiner à la trace dans un long 
programme. Par contre, dans une procédure 
BASIC BBC, ce danger est contournable (avec 
aster pour « astérisque ») : 


100 FOR K = 1 TO 10:PROCaster:NEXT:END 
500 DEF PROCaster 

520 LOCAL K 

540 FOR K = 1 TO S:PRINT«**""»:NEXT 
560 ENDPROC 


La commande LOCAL signifie qu'entre les 
lignes 500 et 560 la variable K est une nouvelle 
variable, indépendante de la variable K située 
ailleurs dans le programme, et n’ayant aucun 
effet sur la valeur de ce K ailleurs. Vous remar- 
querez que PROCstars est une procédure sans para- 
mètres. 

REPEAT...UNTIL est une forme syntaxique de bou- 
cle, dans laquelle l’itération se poursuit jusqu’à 
ce que l’expression conditionnelle suivant UNTIL 
soit vraie. Le contrôle passe alors sur l’instruc- 
tion suivant UNTIL. Par exemple : 


200 DATA 12,234,31,45,65,0,76,81 

250 REPEAT 

300 READ nombre:somme = somme + 
350 UNTIL nombre = 0 

400 PRINT « la somme est de »; somme 


nombre 


Cette dernière syntaxe est beaucoup plus lisi- 
ble et bien moins sujette à erreurs que les bou- 
cles GOTO ou FOR..NEXT virtuelles. 

Le BASIC BBC comporte des aides au dépis- 
tage d’erreurs : TRACE, ON ERROR, et ERL. TRACE per- 
met de suivre à la trace, et à l’écran, les lignes 
de programmes exécutées. ON ERROR GOTO ou ON 
ERROR GOSUB signifie qu’en cas d’erreur fatale à 
la bonne exécution du programme (y compris 
pour la touche d’« échappement », ESCAPE) le 


Le graphique BBC 
Les commandes graphiques Basic du micro BBC 
sont les suivantes : 


MODE 
Détermine le mode d'affichage par MODE N, 
oùN-0Dà7: 
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Les micro-ordinateurs BBC modèle A n'ont 
accès qu'aux modes 4, 5, 6 et 7. Le modèle B 
permet l’accès à tous les modes graphiques. 
Pour les modes 0 à 6, il est possible de modifier 
le jeu de caractères par la commande VDU 

(de visualisation). Les caractères télétexte du 
mode 7 sont intangibles et ne correspondent 


pas au code standard ASCII. 


COLOUR 
Attribue une couleur parmi les seize au texte et 
au fond, selon le mode retenu. 


COLOUR N 

N est compris entre 0 et 15 pour la couleur du 
texte, et entre 128 et 143 pour la couleur du 
fond. La couleur attribuée par chaque valeur de 
N ne reste pas la même d’un mode à l’autre. Le 
guide de l'utilisateur donne la correspondance 
entre les valeurs de N et les couleurs, selon le 
mode. 


vou 

Commande très utile, VDU A équivaut à PRINT CHRSIAI. 
De même, VDU ABC a le même effet que PRINT 
CHRSIAÏ;CHRSIB;CHRSICI, cela veut dire que toutes les 
routines de graphique et de texte sous le 
contrôle de codes 32CHR$, qui sont en doublet par 
rapport à la plupart des commandes graphiques 
BASIC, pourront être mises en œuvre avec 
quelques commandes VOL. 


CLG 

Vide la partie graphique de l'écran courant, et 
rapatrie le curseur sur sa position de départ, 
dans le coin inférieur gauche de l'écran. 


Programmation basic px 


contrôle passera sur une routine de traitement 
des erreurs définie par l’utilisateur (ce peut être 
l'affichage de la valeur des variables). ERL est 
une variable système comportant le numéro de 
la ligne responsable de l’erreur. 

Le micro BBC comporte de multiples exten- 
sions BASIC, comme les appels du système 
d'exploitation, la commande de l’unité de 
visualisation (le moniteur), les diverses variables 
système, ainsi que l’assembleur. 


CLS 

Vide la partie texte de l'écran, et rapatrie le 
curseur sur sa position de départ, en haut à 
gauche de l’écran. Tout graphique sera 
également effacé. 


DRAW 
Tire des lignes à l'écran selon les modes 0, 1,2, 
4 et 5. De syntaxe : 


DRAW X,Y 


Le point défini par les coordonnées X et Ÿ 
représente la fin de la ligne. Le point de départ 
peut être soit le point terminal de la dernière 
ligne tracée, soit un point défini par une 
commande MOVE. 


GCOL 
Détermine les couleurs courantes de fond et 
d'affichage. La syntaxe en est : 


GCOL NM 


N donne l'emploi des couleurs (0 à 4); M définit la 
couleur logique selon les mêmes principes que 
COLOUR. N a les effets suivants : 

— 0 : passe la couleur spécifiée par M; 

— 1: OÙ logique (DR) M avec la couleur présente; 
— 2,: ET logique (AND) M avec la couleur présente; 
— 3 : OÙ logique exclusif (0R) M avec la couleur 
présente; 

— 4 : inverse la couleur présente. 


MOVE 
Positionne le curseur graphique sur un point 
déterminé par : 


MOVE X,Y 


Avec le même effet que DRAW, mais sans tirer 
de ligne. 


PLOT 

Utilisable pour de nombreuses fonctions 
graphiques, y compris le tracé d’un point, 
d'une ligne et d’un triangle : 


PLOT K,X,Y 


K définit le type de graphique tracé (par PLOT) 
selon des valeurs comprises entre 0 et 255. Cela 
détermine le type de lignes à tracer et les 
couleurs qu'elles prennent selon la liste figurant 
dans le guide de l'utilisateur. 


POINT 
Donne le numéro en rapport avec la couleur de 
l'écran logique, pour la coordonnée spécifiée : 


NUMVAR = POINT (X,Y) 
NUMVAR est une variable numérique. 
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Langage machine 


Moniteur de mémoire 


Le système de numération hexadécimale paraît bien compliqué, 
mais il se révèle un moyen extrêmement utile pour comprendre 
le maniement des adresses et de leur contenu. 
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A ce stade de notre cours de code machine, 
revenons en arrière pour revoir la question de la 
représentation des nombres. Le système déci- 
mal, que nous utilisons la plupart du temps, 
nous est déjà familier, et nous avons étudié le 
système binaire. Il ne faut pas oublier que ces 
deux systèmes ne sont que des expressions diffé- 
rentes du même concept : le nombre. La plupart 
des humains, par exemple, ont le même nombre 
de doigts à chaque main. On peut dire qu’il y en 
a cinq, d’autres diront five, fünf ou penta; mais 
nous voyons tout de suite qu’il s’agit de la 
même quantité ou du même nombre — seul le 
système de représentation diffère. Il est diffé- 
rent mais équivalent. Il y a correspondance uni- 
voque entre tous les nombres, qu’ils soient 
exprimés en français ou dans une autre langue, 
et tous ces systèmes possèdent une logique 
interne. L’arithmétique conduit aux mêmes 
résultats, quelle que soit la langue utilisée pour 
décrire les termes d’une expression arithmé- 
tique. 

Les systèmes de numération sont tout à fait 
analogues à différentes langues. Le nombre de 
doigts d’une main humaine normale ne varie 
pas suivant qu’on l’appelle cinq ou five, ni si on 
l'écrit 5 ou 101b (b désignant ici le système 
binaire). Les seules raisons de choisir l’un ou 
l’autre système sont soit l’usage, soit la commo- 
dité. 

Il nous semble pratique d’utiliser la représen- 
tation décimale, d’abord parce que c’est le 
système le plus communément employé autour 
de nous. Mais ce n’est pas le seul. Les montres 
numériques, par exemple, font appel à un 
curieux système d’arithmétique : en partie déci- 
mal, en partie modulo 60 (il y a 60 minutes dans 
1 heure et 60 secondes dans 1 minute) et en par- 
tie modulo 24 (24 heures par jour). Avant 1971, 
la monnaie britannique se comptait par unités 
de 12 (pence dans un shilling) et de 20 (shillings 
dans une livre). Il fallait des années pour 
apprendre ce système aux écoliers — et combien 
de gens savaient vraiment comment exprimer 
des shillings et des pence en fractions décimales 
d’une livre? 

En parlant d’ordinateurs, il nous a semblé 
instructif de commencer par les nombres binai- 
res, car ils représentent très bien le fonctionne- 
ment électrique des ordinateurs, qui n’est autre 
qu’une suite d’états de commutateurs ouverts 
ou fermés. Si nous ne voulions parler que 
d’octets, le système binaire remplacerait avanta- 
geusement le système décimal — il est extraordi- 


nairement facile de transcrire un octet binaire 
en nombre décimal avec un peu de pratique. 
Malheureusement, les adresses de mémoire en 
particulier et les nombres utiles en général sont 
habituellement trop grands pour s’écrire dans 
un octet, de sorte que les programmeurs et les 
ingénieurs informaticiens ont ressenti la néces- 
sité d’utiliser un système de numération compa- 
tible avec le système binaire, tout en ayant la 
portée du décimal. Deux systèmes ont ainsi été 
choisis : l’hexadécimal et l’octal. Le premier, 
devenu standard en micro-informatique, est 
abrégé en hex et fondé sur le nombre 16. 
L’octal, basé sur 8, a également été largement 
appliqué, mais il est progressivement remplacé 
par le système hex. 


L'utilisation 
des nombres hex 


En considérant les représentations décimale et 
binaire, nous avons vu deux conséquences du 
choix de la base numérique : la base est le nom- 
bre de chiffres nécessaires dans le système, et 
c’est le facteur multiplicatif dans la notation 
positionnelle. Par exemple, il y a dix chiffres 
dans le système décimal (0 à 9), et la valeur d’un 
chiffre décimal est multipliée par dix chaque 
fois qu’il se décale vers la gauche dans un 
nombre décimal. 

L’hexadécimal requiert donc 16 chiffres : ce 
sont les chiffres 0 à 9 et les lettres A à F. Comp- 
ter en hex ne consiste qu’à manipuler les chif- 
fres et les réutiliser en notation positionnelle. Le 
nombre hex suivant 9 est donc A (10 décimal); 
ensuite vient B; puis C; et ainsi de suite jusqu’à 
F (15 décimal). On a épuisé les chiffres, et le 
nombre suivant F est donc 10 (prononcez « un 
zéro hex ») qui correspond au 16 décimal. Cela 
nous montre comment utiliser les chiffres, la 
valeur des colonnes dans un nombre hex à plu- 
sieurs chiffres étant multipliée par 16 à chaque 
décalage vers la gauche. Dans les nombres déci- 
maux, nous appelons les colonnes : unités, 
dizaines, centaines et milliers. En comparaison, 
dans un nombre hex les colonnes sont : unités, 
seize, deux cent cinquante-six et quatre mille 
quatre-vingt-seize. Par rapport au changement 
de colonnes en binaire, on voit l’avantage 
majeur des nombres hex : au lieu d’un nombre 
binaire à quatre bits, il suffit d’un seul chiffre 
hex (0 à 15 décimal). Voici quelques exemples 
pour illustrer cela. 


Décimal Binaire Hex 
0 00000000 0 
1 00000001 1 
2 00000010 2 
3 00000011 3 
7 00000111 7 
8 00001000 8 
9 00001001 9 

10 00001010 A 
11 00001011 B 
12 00001100 C 
13 00001101 D 
14 00001110 E 
15 00001111 F 
16 00010000 10 
17 00010001 11 
24 00011000 18 
25 00011001 19 
26 00011010 1A 
27 00011011 1B 
31 00011111 1F 
32 00100000 20 
33 00100001 21 


Un octet de 8 bits s’écrit donc avec huit chif- 
fres binaires ou deux chiffres hex : 


041255 en décimal 
00000000 à 11111111 en binaire 
O0 à FF en hex 


Pour convertir un nombre hex en binaire, 
il suffit donc d’exprimer chaque chiffre hex 
comme un nombre binaire de 4 bits. Si un nom- 
bre d’un octet s’écrit comme un nombre hex de 
deux chiffres, alors le chiffre hex de gauche cor- 
respond aux quatre chiffres binaires de gauche, 
tandis que le chiffre hex de droite correspond 
aux quatre chiffres binaires de droite. En cou- 
pant ainsi un octet en deux, on obtient deux 
demi-octets. Le demi-octet de gauche, corres- 
pondant au chiffre hex de gauche, est appelé 
demi-octet supérieur ou plus significatif; et 
celui de droite, l’inférieur ou le moins signifi- 
catif. Voici un exemple : 


Demi-octet Demi-octet 
supérieur inférieur 


206 = 1100 fo “CE 
t t L 


décimal équivalent binaire équivalent hex 


Il est important de se familiariser autant que 
possible avec le système hexadécimal, pour la 
simple raison qu’il est plus facile de manipuler 
les nombres hex que les octets binaires. Pour 
vous en convaincre, il vous faudra un peu de 
pratique non seulement avec des exemples 
numériques, mais surtout avec des adresses de 
mémoire et les contenus des octets de mémoire. 
Une fois que vous aurez compris cela — et ce 
sera très bientôt —, vous vous demanderez 
comment vous avez pu employer le système 
décimal. 


Dans ce numéro du cours de code machine, 
nous donnons des programmes pour le BBC 
Micro, le Commodore 64 et le Spectrum, qui 
nous permettent de regarder le contenu de cer- 
tains octets de mémoire. Ces programmes, que 
nous avons appelés « Mempeek », vous deman- 
dent d’abord de spécifier l’« adresse de départ », 
puis de donner le nombre d’octets que vous 
voulez considérer. Si, par exemple, vous spéci- 
fiez l’octet 1953 comme point de départ et si 
vous souhaitez que le contenu des quatre octets 
suivants soit affiché, alors l’écran montrera le 
nombre décimal 1953 dans la colonne de gau- 
che, puis listera les contenus des octets 1953, 
1954, 1955 et 1956 dans les quatre colonnes 
suivantes. 

N'oubliez pas que, si la machine montre que 
l’octet 1956 contient le nombre décimal 175, 
cela signifie que, dans l’une des puces de 
mémoire, une zone que la machine appelle 
l’octet 1956 comprend une séquence de huit 
niveaux de tension. Si O0 V est représenté par 0, 
et 5 V par 1, alors l’octet 1956 porte une 
séquence de tension de 10101111. Nous choisis- 
sons d’interpréter cela comme un nombre 
binaire, dont l’équivalent décimal est 175. 

Il est essentiel de se rappeler que nous utili- 
sons une sorte de raccourci presque chaque fois 
que nous parlons d’ordinateurs; traduire cela 
en termes physiques est toujours salutaire et 
devrait aider à éviter des confusions. 

Les contenus d’un octet affichés sur l’écran 
ne sont pas les contenus « réels ». Ce que nous 
voyons, ce sont des caractères qui ont été assi- 
gnés aux séquences de tension des octets. En 
interprétant ces valeurs comme des nombres 
binaires, et en convertissant ces derniers en déci- 
maux, nous franchissons une étape de plus pour 
convertir les nombres décimaux en caractères 
ASCII (American Standard Code for Informa- 
tion Interchange). C’est ce caractère qui est affi- 
ché sur la dernière colonne. Ce code, internatio- 
nalement reconnu et appliqué à la plupart des 
ordinateurs, substitue des nombres décimaux 
compris entre 0 et 127 à tous les caractères d’un 
clavier (historiquement, un clavier de téléscrip- 
teur). Dans ce code, le nombre décimal 65 cor- 
respond au caractère majuscule À, 66 au B, 67 
au C, et ainsi de suite. Parmi les caractères non 
alphabétiques, 32 représente l’espace, 42 l’asté- 
risque, 13 le retour de chariot, etc. 

Les caractères ASCII pouvant être imprimés 
commencent au 32 et se terminent au 127. En 
dehors de cet intervalle, les codes sont soit indé- 
finis, soit non imprimables, soit spécifiques à 
des machines particulières. C’est pourquoi, 
lorsque nous faisons tourner les programmes 
Mempeek, le moniteur affiche un point pour 
tout octet contenant un tel nombre. Dans le 
prochain numéro, nous verrons l’ensemble des 
caractères ASCII compris entre 0 et 127. 

Cette investigation est particulièrement utile 
pour comprendre le code machine, pour deux 
raisons importantes. Premièrement, cela met en 
évidence le fait que l’interprétation des conte- 
nus de mémoire est entièrement une question de 
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choix. On peut dire qu’une adresse contient un 
nombre, une adresse, un caractère codé, une 
instruction, ou tout ce que vous voudrez. 
Deuxièmement, cela donne une notion bien plus 
claire de la mémoire, en particulier des zones de 
mémoire qui contiennent des données, dont cer- 
taines sont utilisées par le système d’exploita- 
tion de la machine et d’autres par vous. 

Les données du système d’exploitation com- 
prennent tous les messages d’erreur ou d’attente 


Variables système du Commodore 


43,44 Début du TEXTE de 
PROGRAMME BASIC. 
4546 Début des VARIABLES 


BASIC. 
47,48 Début des TABLEAUX 
BASIC 


49,50 Fin des TABLEAUX 
BASIC. 

51,52 Bas du STOCKAGE de 
CHAINES BASIC. 

55,56 Haut du STOCKAGE de 
CHAINES BASIC. 


Exemple 

Utilisez le programme 
Mempeek de la page 
suivante pour inspecter 
les contenus de ces 
octets. Votre écran 
pourrait, par exemple, 
afficher les nombres 
suivants : 


RS SC CS 


La première colonne est 
l'adresse du premier 
octet atteint. Les 
deuxième et troisième 
colonnes affichent le 
contenu des octets 43 
et 44. Ce sont les octets 
de décalé et de page de 
l'adresse du début de la 
zone de texte BASIC. 


8*256 + O = 2048 


Les quatrième et 
cinquième colonnes 
sont les octets de 
décalé et de page pour 
la fin de la zone de 
texte BASIC. L'adresse 
est ainsi calculée : 


9*256 + 11 = 2315 
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COMMODORE 64 


SSSR RRRESEE 


OO! 


“61007 


eTetera 070707 7070007 RSR RSR Re OO 


— tels que READY, NONSENSE IN BASIC, etc. — ; tout 
ce qui peut être dit à l’utilisateur est codé en 
ASCII et stocké en mémoire. Vous n’y avez 
peut-être jamais pensé, mais ce coup d’œil à 
l’intérieur de la machine révèle les limites de son 
« intelligence ». Il est évident que notre intelli- 
gence est d’une autre nature : nous ne mémori- 
sons pas de messages ainsi, nous concevons une 
pensée, puis formons une combinaison appro- 
priée de mots pour l’exprimer. 


FTLLLES 


Commodore b4 


+ REM PPTTTLLL LES 
REM * CcOMMODORE 


REM nresepireerrene? 
PRINT cHR$C147) 
PRINT cHR$#C 142) 


sonner e* 
MEMPEEK 1 * 


arr nana" 


REM EFFAcE L' ECRAN 


CLLES 


UR ARRETER) 


NO 
PR tel " 


FPPTTILLLES 
T0 can + NO - À? STEP 4 


250 H$ = 
100 PRINT 8: TAB(B) ? 


FOR c=07%0 5 


550 = PEEKCE + Cr:PK«e = 
600 PRINT Tate + se C) 3PK3 
650 1E- PK = o THEN PK# = cHR$ti22) 
700 1F cpK > 31) AND cpK < 128) THEN PK#& = CHR$# C PK) 
750 H$ = H$ + PK# 
sa0 NEXT C 
250 PRINT TaB(52) sH$ 
200 NEXT B 
950 1F No = @ THEN up = i 
1000 NEXT LP 
1050 REM SR mme 


Petit à petit. 


Acorn Computers a produit deux des plus beaux exemples 
de la micro-informatique britannique : le BBC Micro et l’Electron. 
Il y a quelques années à peine, cette firme naïissait. 


Le fondateur d’Acorn, Chris Curry, est un 
ancien employé — et un ami très proche — de 
sir Clive Sinclair, qui l’engagea en 1965 pour le 
salaire royal de 11 livres par semaine (environ 
150 francs!). 

Devenu employé de la Sinclair Radionics, 
Curry, ingénieur de recherche, fut nommé res- 
ponsable d’un projet qui aboutit à la mise sur le 
marché de la calculatrice Executive, en 1971. 
Au cours des cinq années qui suivirent, il se 
consacra à la mise au point de machines de ce 
type, où l’on voit aujourd’hui les ancêtres 
directs des micro-ordinateurs domestiques. En 
1975, Sinclair Radionics cessa toute activité, et 
Curry s’associa avec Sinclair pour une nouvelle 
opération nommée « Science in Cambridge » : 
il s’agissait de vendre des composants électro- 
niques sous forme de kits. 

Une calculatrice montre-bracelet se vendit 

- particulièrement bien. Mais Curry s’intéressait 
3 aux ordinateurs construits à partir d’un circuit 
imprimé, tels qu’ils commençaient à apparaître 
aux États-Unis. Il entreprit d’en construire un. 


Chris Curry 


Herman Hauser 
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Ce fut le MK 14 (microprocesseur à 14 puces, 
livré en kit), qui comprenait un microprocesseur 
de chez National Semiconductors, une RAM de 
256 octets, une petite ROM abritant un pro- 
gramme moniteur, et les composants nécessai- 
res pour un affichage à huit chiffres, utilisant 
des diodes électroluminescentes. 

Curry s’aperçut aussi que la compagnie était 
sans cesse amenée à fournir conseils et idées aux 
amateurs d’électronique qui lui téléphonaïient ; 
il décida d’engager Herman Hauser, qui prépa- 
rait alors un doctorat à Cambridge, afin de 
s’occuper de ces problèmes. Mais il eut bientôt 
de profondes divergences avec Sinclair, et 
décida de fonder sa propre compagnie. Ce fut la 
Cambridge Processor Unit (en abrégé CPU; 
allusion à central processing unit, « unité cen- 
trale »). Hauser devint son associé, et tous 
deux, installés dans un petit bureau de Bridge 
Street, à Cambridge, se firent experts-conseils 
en électronique et en informatique. 

Le succès du MK 14 et l’évolution du marché 
aux Etats-Unis montraient clairement que les 
amateurs étaient à la recherche d’un ordinateur 
intégré dans un boîtier, et qui parlerait BASIC. 
Au cours d’un projet pour un client, CPU avait 
rédigé une version très rapide de ce langage, 
destinée au contrôle des machines; la firme 
décida de l’implanter sur un appareil qu’elle 
mettrait en vente. Ce fut l’ Atom, et à cette occa- 
sion CPU prit le nom d’Acorn. Il s’agissait 
avant tout de conquérir le marché éducatif; 
mais beaucoup de lycées estimèrent que le BASIC 
utilisé différait par trop des standards établis 
par Microsoft pour pouvoir être acceptable. 
Toutefois l’Atom eut beaucoup de succès 
auprès des particuliers. Une version améliorée, 
le Proton, fut mise au point à l’intention des 
laboratoires et des universités. 

Le Proton en était au stade de préproduction 
lorsque, en 1981, Curry apprit que la B.B.C. 
était à la recherche d’un appareil permettant la 
mise en application de ses cours d’informati- 
que. Il devait être d’usage facile, même pour les 
débutants, avoir de grosses possibilités, et pour- 
tant rester de prix raisonnable (le prix imposé 
était de 200 livres, soit environ 2 500 francs). 

Curry. entreprit non d’améliorer encore le 
Proton, mais de construire quelque chose de 
nouveau, qui ferait la démonstration des capa- 
cités du microprocesseur 6502. Après une lutte 
sans merci face à Sinclair Research (qui propo- 
sait le Spectrum), Acorn obtint le contrat, et 


2 sortit le micro-ordinateur BBC. 


PROGRAMME 


N° 14 


LES INSTRUCTIONS READ ET DATA 


L’instruction DATA permet de prédéfinir des don- Exemple : 
nées à l’intérieur du programme lui-même. Ces 

données sont ensuite lues dans les variables SLIST 
choisies par l’instruction : 


« BEAD variable » S REM SAISIE DES DATAS 
1 


Ces DATAS sont en général données en tout début = si " hole 

de programme. L’ordre dans lequel sont saisies CRE RAR Re 
les données détermine l’indice de ces mêmes 22 REA A1 

données. IQ READ À 


48 READ A3 
SO READ Rà 


Dans ce programme, la machine lit successivement les valeurs 16, 15, 0, 3 dans les variables : 
Al, A2, A3, A4 


A l'issue de quoi: Al = 16 
A2 = 15 
25 — Ÿ 
A4 = 3 


A ce début de programme ajoutons, par exemple, un petit calcul de moyenne. On obtient : 


SLIST 


5 REM SAISIE DES DATAS 
10 DATA 16, 15, @, 3 

15 REM LECTURE DES DATAS 
20 READ Ai 

TQ READ AZ 

4 READ AZ 

50 READ À4 

S2 REM CALCUL DE MOYENNE 


SS PRINT "CALCUL DE MOYENNE": PRINT : PRINT 

57 REM AFFICHAGE DES NOTES 

ED PRINT “PREMIERE NOTE :":A1 

7@ PRINT "DEUXIEME NOTE :"3AZ SRUN 

SO PRINT "TROISIEME NOTE :"3AZ CALCUL DE MOYENNE 

90 PRINT "QUATRIEME NOTE :"3:A4 

95 REM ON SAUTE DES LIGNES PREMIERE NOTE : 16 
108 PRINT : PRINT : PRINT DEUXIEME NOTE : 5 
107 REM ON IMPRIME LA MOYENNE TROISIEME NOTE : @ 
119 INVERSE : PRINT "MOYENNE :"3:CA1 + A? + A3 + A4) / 4 GUATRIEME NOTE : Z 


120 NORMAL 
139 END MOYENNE : 8.5 


dont l’organigramme est : 


SAISIE DES DATAS 


LECTURE DES DATAS EN A1, A2, A3, A4 


AFFICHAGE DES A1, A2, A3, A4 


CALCUL DE LA MOYENNE 
AFFICHAGE DE LA MOYENNE 


L’instruction 20 : 
20 READ A 


lit la première donnée 16 dans A1. Le compteur 
de DATA (géré par le BASIC) progresse de 1. 
L'’instruction 30 : 


30 READ A2 


lit la deuxième donnée dans A2, etc. 

On peut utiliser l'instruction READ de manière 
différente en indiquant, par exemple, la fin des 
DATAS par la note 21. On obtient le programme 
suivant : 


SLIST 


4 REM ON MET LE CONPTEUR TT A @ 
1 TT = @ 
ré REM SAISIE DES DATAS 


10 DATR 16: 15 @r 3, 21 

19 REM LECTURE DES DATAS 

2 READ ZN 

25 REM QUAND ZN = 21 IMPRIMER LA 
MOYENNE 

a) IF ZN = Z1 THEN GOTO 1008 

45 PRINT ZN 

50 TT = TT + ZN 

60 NT = NT + 1 

70 GOTO <@ 

100 REM ON IMPRIME LA MOYENNE 

1082 PRINT "MOYENNE DES NOTES :"3 
TA #2NM 


SRUN 
16 
15 


MOYENNE DES NOTES : 6.5 


Grâce à la variable TT, on dispose d’un comp- 
teur que l’on initialise à O0 en début de pro- 
gramme et auquel on rajoute la valeur de cha- 
que ZN après chaque impression (ligne 50). 
De même, en NT on dispose d’un compteur de 
note qui permet ainsi d'obtenir directement 
la moyenne en 1 000. Moyenne, donc, qui vaut 
TT/NT (TT, total de toutes les notes; NT, 
nombre de notes). 

DATA peut être utilisé aussi sur plusieurs lignes. 
Par exemple : 


10 DATA 100, 200, 0, 50 
20 DATA 50, 25 
30 DATA 20 


Ce qui est équivalent à la ligne : 
10 DATA 100, 200, 0, 50, 50, 25, 20 


DATAS ET CARACTÈRES NON NUMÉRIQUES 


Les DATAS contenant des caractères alphanumé- 
riques doivent se placer entre guillemets. Si les 
guillemets sont absents, la virgule fera office de 
séparateur. Voici un petit exemple : 


SLIST 


S REM SAISIE DU DATA ALPFHANUMERIQUE 
1Q DATA “45 RUE DE LA PAIX" 

15 REM LECTURE DU DATA 

20 READ 74 

25 REM ON IMPRIME LE DATA 

42 PRINT Z+ 


SRUN 
43 RUE DE LA PAIX 


On peut aussi considérer des nombres comme 
caractères alphanumériques et donc être lus 


comme une chaîne de caractères. Ces nombres 
doivent être placés entre guillemets. En voici un 
petit exemple : 


SLIST 

S REM SAISIE DU DATA 

10 DATA "522000" 

15 REM LECTURE DU DATA 

ZQ READ 74 

Z$S REM ON IMPRIME LE DATA 

30 PRINT Z# 

25 REM ON IMPRIME LES 2 CARACTERES DE 
GAUCHE DU DATA 

4D PRINT LEFT$ (Z$;, 2) 


FRUN 
:00000 
50 


